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Foreword 



id , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

x the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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Scope 



The present document lists the 3GPP specific Diameter protocol codes, including the AVP codes and Experimental 
result codes. 

This document lists also the application identifiers assigned to 3GPP specific Diameter applications by IANA and the 
Diameter command code range which is assigned to 3GPP by IANA. 



References 
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• References are either specific (identified by date of publication, edition number, version number, etc.) or 
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• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[I] 3GPP TS 29.228: " IP Multimedia (IM) Subsystem Cx and Dx interfaces; Signalling flows and 
message contents". 

[2] 3GPP TS 29.229: " Cx and Dx interfaces based on the Diameter protocol; Protocol details". 

[3] 3GPP TS 29.328: " IP Multimedia (IM) Subsystem Sh interface; Signalling flows and message 
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[4] 3GPP TS 29.329: " Sh Interface based on the Diameter protocol; Protocol details" . 

[5] 3GPP TS 32.299 "3GPP Diameter charging application". 

[6] 3GPP TS 29.234: "3GPP System to WLAN Interworking; Stage 3 Description". 

[7] 3GPP TS 29.109: " Generic Authentication Architecture (GAA); Zh and Zn Interfaces based on 

the Diameter protocol; Protocol details". 

[8] 3GPP TS 29.209: " Technical Specification Group Core Network; Policy control over Gq 

interface". 

[9] IETF RFC 3588: "Diameter Base Protocol". 

[10] IETF RFC 3589: "Diameter Command Codes for Third Generation Partnership Project (3GPP) 

Release 5". 

[II] IANA"s Enterprise-Numbers: http://www.iana.org/assignments/enterprise-numbers 

[12] IANA"s AAA parameters register: ftp://ftp.iana.org/assignments/aaa-parameters/ 

[13] 3GPP TS 29.061: "Interworking between the Public Land Mobile Network (PLMN) supporting 

packet based services and Packet Data Networks (PDN)". 

[14] 3GPP TS 32.296: "Telecommunication management; Online Charging System (OCS): 

Applications and interfaces;". 

[15] 3GPP TS 29.210: " Charging rule provisioning over Gx interface". 
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3.1 



Definitions and abbreviations 



Definitions 



For the purposes of the present document, the following terms and definitions apply. 
3GPP specific: A definition which is used in conjunction with the 3GPP"s vendor identifier. 



3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 



AVP 

CR 

IANA 

IETF 

LS 



Attribute- Value-Pair 

Change Request 

Internet Assigned Numbers Authority 

Internet Engineering Task Force 

Liaison Statement 



4 Application identifiers 

The Diameter applications are identified with the application identifiers as specified in the RFC 3588 [9]. There are two 
kind of applications: IETF standards track applications and vendor specific applications. All application identifiers are 
assigned by IANA [12]. This chapter lists the application identifiers asigned by IANA to all 3GPP Diameter 
applications. 

The application identifiers are transferred in Diameter command" s header in the Application-ID field. 

4.1 3GPP specific application identifiers 

The 3GPP specific application identifiers allocated by IANA are listed in the following table. 

Table 4.1 : 3GPP specific application identifiers 



Application identifier 


Application 


3GPP TS 


16777216 


3GPP Cx/Px 


29.228 [1] and 29.229 [2] 


16777217 


3GPP Sh/Ph 


29.328 [3] and 29.329 [4] 


16777218 


3GPP Re 


32.296 [14] 


16777219 


3GPPWx 


29.234 [6] 


16777220 


3GPPZn 


29.109 [7] 


16777221 


3GPPZh 


29.109 [7] 


16777222 


3GPP Gq 


29.209 [8] 


16777223 


3GPPGmb 


29.061 [13] 


16777224 


3GPP Gx 


29.210 [15] 


16777225 


3GPP Gx over Gy 


29.210 [15] 



Command codes 



The command codes are used for communicating the command associated with the Diameter message. The command 
code is carried in the Diameter header"s Command-Code field. The command codes can be divided into standard 
command codes allocated by IANA and experimental command codes for testing purposes only. 
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5.1 



Command codes allocated for 3GPP 



Based on the IETF RFC 3589 [10] the IANA has allocated a standard command code range 300 - 313 for 3GPP. The 
command codes are presented in the following table. 

Table 5.1 : Command codes allocated for 3GPP 



Command code 


Command name 


Abbreviation 


Specified in 
3GPP TS 


300 


User-Authorization-Request/-Answer 


UAR/UAA 


29.229 [2] 


301 


Server-Assignment-Request/-Answer 


SAR/SAA 


302 


Location-lnfo-Request/-Answer 


LIR/LIA 


303 


Multimedia-Auth-Request/-Answer 


MAR/MAA 


304 


Registration-Termination-Request/- 
Answer 


RTR/RTA 


305 


Push-Profile-Request/-Answer 


PPR/PPA 


306 


User-Data-Request/-Answer 


UDR/UDA 


29.329 [4] 


307 


Profile-Update-Request/-Answer 


PUR/PUA 


308 


Subscribe-Notifications-RequestAAnswer 


SNR/SNA 


309 


Push-Notification-Request/-Answer 


PNR/PNA 


310 


Boostrapping-lnfo-Request/Answer 


BIR/BIA 


29.109 [7] 



Editors note: The following command codes have been allocated to 3GPP, but they have not been used yet. 



311 








312 








313 









Vendor identifier 



The vendor identifier (also known as Enterprise number) indicates the vendor specific attributes, result codes and 
application identifiers in Diameter commands. The vendor identifier is used in the Vendor-ID field of the AVP header 
and in the Vendor-Id AVP. The Vendor-Id AVP is used to identify the vendor in the Vendor-Specific-Application-Id 
and Experimental-Result-Code grouped AVPs. 



6.1 



3GPP"s vendor identifier 



The IANA has allocated a vendor identifier value 10415 for 3GPP [11]. 



7 Attribute- Value-Pair codes 

The AVP codes are used together with the vendor identifier to identify each attribute uniquely. There are multiple AVP 
namespaces. The IETF IANA namespace, that is, the AVPs with vendor identifier zero or without vendor identifier, is 
controlled by IANA. Each vendor controls the AVP codes within their AVP namespaces. 



7.1 3GPP specific AVP codes 



The 3GPP specific AVPs have the Vendor-Specific bit ('V bit) set in the AVP header and they carry the 3GPP"s vendor 
identifier in the Vendor-ID field of the AVP header. The 3GPP specific AVP codes are presented in the following table. 
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Table 7.1 : 3GPP specific AVP codes 



AVP 
Code 


Attribute Name 


Data Type 


Specified in the 
3GPP TS 


Note: The AVP codes from 1 to 255 are reserved for backwards compatibility with 3GPP RADIUS Vendor 
Specific Attributes (See TS 29.061 [1 3]) 


Note: The AVP codes from 256 to 299 are reserved for future use. 


| | | 29.234 [6] 


Note: The AVP codes from 300 to 399 are reserved for TS 29.234 


| | | 29.109 [7] 


Note: The AVP codes from 400 to 499 are reserved for TS 29.109 


500 


Abort-Cause 


Enumerated 


29.209 [8] 


501 


Access-Network-Charging-Address 


Address 


502 


Access-Network-Charging-ldentifier 


Grouped 


503 


Access-Network-Charging-ldentifier-Value 


OctetString 


504 


AF-Application-ldentifier 


OctetString 


505 


AF-Charging-ldentifier 


OctetString 


506 


Authorization-Token 


OctetString 


507 


Flow-Description 


IPFilterRule 


508 


Flow-Grouping 


Grouped 


509 


Flow-Number 


Unsigned32 


510 


Flows 


Grouped 


511 


Flow-Status 


Enumerated 


512 


Flow-Usage 


Enumerated 


513 


Gq-Specific-Action 


Enumerated 


514 


Max-Requested-Bandwidth 


Unsigned32 


515 


Max-Requested-Bandwidth-DL 


Unsigned32 


516 


Max-Requested-Bandwidth-UL 


Unsigned32 


517 


Media-Component-Description 


Grouped 


518 


Media-Component-Number 


Unsigned32 


519 


Media-Sub-Component AVP 


Grouped 


520 


Media-Type 


Enumerated 


521 


RR-Bandwidth 


Unsigned32 


522 


RS-Bandwidth 


Unsigned32 


523 


SIP-Forking-lndication 


Enumerated 


Note: The AVP codes from 524 to 599 are reserved for TS 29.209 


600 


Visited-Network-ldentifier 


OctetString 


29.229 [2] 


601 


Public-Identity 


UTF8String 


602 


Server-Name 


UTF8String 


603 


Server-Capabilities 


Grouped 


604 


Mandatory-Capability 


Unsigned32 


605 


Optional-Capability 


Unsigned32 


606 


User-Data 


OctetString 


607 


SIP-Number-Auth-ltems 


Unsigned32 


608 


SIP-Authentication-Scheme 


UTF8String 


609 


S IP-Authenticate 


OctetString 


610 


SIP-Authorization 


OctetString 


611 


SIP-Authentication-Context 


OctetString 


612 


SIP-Auth-Data-ltem 


Grouped 


613 


SIP-ltem-Number 


Unsigned32 


614 


Server-Assignment-Type 


Enumerated 


615 


Deregistration-Reason 


Grouped 


616 


Reason-Code 


Enumerated 


617 


Reason-Info 


UTF8String 


618 


Charging-lnformation 


Grouped 


619 


Primary-Event-Charging-Function-Name 


DiameterURI 


620 


Secondary-Event-Charging-Function-Name 


DiameterURI 


621 


Primary-Charging-Collection-Function-Name 


DiameterURI 


622 


Secondary-Charging-Collection-Function-Name 


DiameterURI 


623 


User-Authorization-Type 


Enumerated 


624 


User- Data-AI ready-Avai lable 


Enumerated 


625 


Confidentiality-Key 


OctetString 


626 


Integrity-Key 


OctetString 


627 


User- Data- Request-Type 


Enumerated 


628 


Supported-Features 


Grouped 
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629 


Feature-List-ID 


Unsigned32 




630 


Feature-List 


Unsigned32 


631 


Supported-Applications 


Grouped 


Note: The AVP codes from 632 to 699 are reserved for TS 29.229. 


700 


User-Identity 


Grouped 


29.329 [4] 


701 


MSISDN 


OctetString 


702 


User-Data 


OctetString 


703 


Data- Reference 


Enumerated 


704 


Service-Indication 


OctetString 


705 


Subs-Req-Type 


Enumerated 


706 


Requested-Domain 


Enumerated 


707 


Current-Location 


Enumerated 


708 


Identity-Set 


Enumerated 


Note: The AVP codes from 709 to799 are reserved for TS 29.329. 


| | | 32.299 [5] 


Note: The AVP codes from 800 to 899 are reserved for TS 32.299 


| | | 29.061 [13] 


Note: The AVP codes from 900 to 999 are reserved for TS 29.061 


| | | 29.210 [15] 


Note: The AVP codes from 1000 to 1099 are reserved for TS 29.210 



8 



Experimental result codes 



The Diameter answer messages must carry either Result-Code AVP or Experimental-Result AVP. The values of Result- 
Code AVP are controlled by IANA. The Experimental-Result AVP is a grouped AVP containing the Vendor-Id AVP 
and Experimental-Result-Code AVP, thus the experimental result codes are controlled in a vendor-specific manner. 



8.1 3GPP specific result codes 



The 3GPP specific result codes are always transferred in the Experimental-Result AVP, which has the Vendor-Id with 
value of 3GPP"s vendor identifier. The 3GPP specific result codes shall follow the same classification as defined for the 
values of Result-Code AVP in IETF RFC 3588 [9]. That means, the result codes are grouped to following ranges: 

lxxx (Informational) 

2xxx (Success) 

4xxx (Transient Failures) 

5xxx (Permanent Failures) 

8.1.1 Informational 

The Informational result codes shall use the values from 1001 to 1999 in the Experimental -Result-Code AVP. 
Editor's note: No informational result codes have been yet defined in 3GPP. 

8.1.2 Success 

The Success result codes shall use the values from 2001 to 2999 in the Experimental-Result-Code AVP. The reserved 
3GPP specific Success result codes are presented in the following table. 
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Table 8.1.2: 3GPP specific Success result codes 



Experimental 
Result Code 


Result text 


Specified in the TS 


2001 


DIAMETER FIRST REGISTRATION 


29.229 [2] 


2002 


DIAMETER SUBSEQUENT REGISTRATION 


2003 


DIAMETER UNREGISTERED SERVICE 


2004 


DIAMETER SUCCESS SERVER NAME NOT STORED 


2005 


DIAMETER SERVER SELECTION 


Note: The Experimental Result Codes from 2006 to 2020 are reserved for the TS 29.229. 


| | 29.109 [7] 


Note: The Experimental Result Codes from 2401 to 2420 are reserved for the TS 29.109. 



8.1.3 Transient Failures 

The Transient Failure result codes shall use the values from 4001 to 4999 in the Experimental -Result-Code AVP. The 
reserved 3GPP specific Transient Failure result codes are presented in the following table. 



Table 8.1.3: 3GPP specific Transient Failure result codes 



Experimental 
Result Code 



Result text 



Specified in the TS 



4100 



DIAMETER USER DATA NOT AVAILABLE 



4101 



DIAMETER PRIOR UPDATE IN PROGRESS 



29.329 [4] 



Note: The Experimental Result Codes from 41 02 to 41 20 are reserved for the TS 29.329. 

32.299 [5] 



Note: The Experimental Result Codes from 41 xx to 41 yy are reserved for the TS 32.299. 



8.1.4 Permanent Failures 

The Permanent Failure result codes shall use the values from 5001 to 5999 in the Experimental-Result-Code AVP. The 
reserved 3GPP specific Permanent Failure result codes are presented in the following table. 
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Table 8.1.4: 3GPP specific Permanent Failure result codes 



Experimental 
Result Code 


Result text 


Specified in the TS 


5001 


DIAMETER ERROR USER UNKNOWN 


29.229 [2] 


5002 


DIAMETER ERROR IDENTITIES DONT MATCH 


5003 


DIAMETER ERROR IDENTITY NOT REGISTERED 


5004 


DIAMETER ERROR ROAMING NOT ALLOWED 


5005 


DIAMETER ERROR IDENTITY ALREADY REGISTERED 


5006 


DIAMETER ERROR AUTH SCHEME NOT SUPPORTED 


5007 


DIAMETER ERROR IN ASSIGNMENT TYPE 


5008 


DIAMETER ERROR TOO MUCH DATA 


5009 


DIAMETER ERROR NOT SUPPORTED USER DATA 


5010 


DIAMETER MISSING USER ID 


Note: The Experimental Result Codes from 501 1 to 5020 are reserved for the TS 29.229. 


| | 32.299 [5] 


Note: The Experimental Result Codes from 5021 to 5040 are reserved for the TS 32.299. 


| | 29.234 [6] 


Note: The Experimental Result Codes from 5041 to 5060 are reserved for the TS 29.234. 


5061 


GQ INVALID SERVICE INFORMATION 


29.209 [8] 


5062 


GQ FILTER RESTRICTIONS 


Note: The Experimental Result Codes from 5063 to 5080 are reserved for the TS 29.209. 


5100 


DIAMETER ERROR USER DATA NOT RECOGNIZED 


29.329 [4] 


5101 


DIAMETER ERROR OPERATION NOT ALLOWED 


5102 


DIAMETER ERROR USER DATA CANNOT BE READ 


5103 


DIAMETER ERROR USER DATA CANNOT BE MODIFIE 
D 


5104 


DIAMETER ERROR USER DATA CANNOT BE NOTIFIED 


5105 


DIAMETER ERROR TRANSPARENT DATA 
OUT OF SYNC 


Note: The Experimental Result Codes from 51 06 to 51 1 9 are reserved for the TS 29.329. 


| | 29.061 [13] 


Note: The Experimental Result Codes from 5120 to 5139 are reserved for the TS 29.061 


| | 29.210 [15] 


Note: The Experimental Result Codes from 51 40 to 51 59 are reserved for the TS 29.21 0. 


| | 29.109 [7] 


Note: The Experimental Result Codes from 5400 to 5419 are reserved for the TS 29.109. 
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Annex A (informative): 

Assignment of the Diameter codes and identifiers in 3GPP 

This annex defines the recommended assignment procedure of Diameter codes and identifiers within the 3GPP. 

A.1 Application identifiers 

If a working group detects it will require a new application identifier, it should contact the 3GPP TSG-CN WG 4 via a 
Liaison Statement. The LS shall contain the name of the Diameter application and a reference to the corresponding 
3GPP TS. The 3GPP TSG-CN WG 4 will then request the application identifier from IAN A. When the application 
identifier is received, the corresponding working group will be informed by 3GPP TSG-CN WG 4 and the table 4. 1 in 
this specification will be updated. 

According to RFC 3588 the creation of a new application should be avoided if at all possible and therefore it is 
recommended to use the existing application identifiers whenever possible. 



A.2 Command codes 

If a working group detects there is a need for a new command code(s) from the 3GPP"s range, it should contact the 
3GPP TSG-CN WG 4 via an LS. The LS shall contain the reference to the 3GPP TS, which specifies the command(s). 
The 3GPP TSG-CN WG 4 will inform the assigned command code(s) to the corresponding working group and the 
table 5.1 in this specification will be updated. 

It should be noted that the standard command codes allocated for 3GPP are scarce resource and getting new ones would 
require IETF specification work to be done. Therefore it is recommended to use the existing command codes whenever 
possible. 



A.3 AVP codes 



If a working group detects a Diameter application needs new 3GPP specific AVP codes, it should contact the 3GPP 
TSG-CN WG 4 via an LS. The LS shall contain the name of the Diameter application and a reference to the 
corresponding 3GPP TS. The 3GPP TSG-CN WG 4 will allocate a range of 100 AVP codes for the application. The 
range will be informed to the corresponding working group and the table 7.1 will be updated in this specification to 
show the reserved range. The working group can use the allocated range as a working assumption when defining the 
actual AVPs. 

When the corresponding working group has specified the AVPs, and the specification has been approved and is under 
CR control, it should inform the AVPs to the 3GPP TSG-CN WG 4 via an LS. The LS should list the used AVP codes 
in the form of the table 7.1. 

If there will be defined new AVPs for a Diameter application through the CR procedure, the assigned AVP range can be 
used, but the 3GPP TSG-CN WG 4 should be also informed about the new AVP codes via an LS. 

Re-using of the existing AVPs is recommended, but special attention should be paid on the use of enumerated AVPs. 
Defining new values for an enumerated AVP should be agreed case by case with the working group responsible of the 
particular enumerated AVP. 3GPP TSG-CN WG 4 shall be informed via an LS about the new values assigned to the 
enumerated AVP. 



A.4 Result codes 

If a working group detects a Diameter application needs new 3GPP specific result codes, it should contact the 3GPP 
TSG-CN WG 4 via an LS. The LS shall contain the name of the Diameter application and a reference to the 
corresponding 3GPP TS. The 3GPP TSG-CN WG 4 will allocate a range of 20 result codes from each required result 
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code group for the application. The ranges will be informed to the corresponding working group and the tables in the 
chapter 8 of this specification will be updated to show the reserved ranges. The working group can use the allocated 
ranges as a working assumption when defining the actual result codes. 

When the corresponding working group has specified the result codes, and the specification has been approved and is 
under CR control, it should convey the codes to the 3GPP TSG-CN WG 4 via an LS. The LS should list the used result 
codes in the form of the tables in chapter 8. 

If there will be defined new result codes for a Diameter application through the CR procedure, the assigned result code 
ranges can be used, but the 3GPP TSG-CN WG 4 should be also informed about the new result codes via an LS. 

Re-using of the existing result codes is recommended. 
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Annex B (informative); 
Change history 



Change history 


Date 


TSG# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


2004-06 


CN#24 


NP-040292 






Version 2.0.0 presented for information and approval 


2.0.0 


6.0.0 


2004-09 


CN#25 


NP-040401 


001 




Correction of Charging application reference 


6.0.0 


6.1.0 


2004-09 


CN#25 


NP-040401 


002 




Correction of the Application-Id code 


6.0.0 


6.1.0 


2004-09 


CN#25 


NP-040401 


003 




Removal of User Data Request Type AVP 


6.0.0 


6.1.0 


2004-09 


CN#25 


NP-040412 


004 


1 


Re-numbering of 3GPP specific AVP codes. 


6.0.0 


6.1.0 


2004-12 


CN#26 


NP-040579 


006 
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